perm filename GRUMP.FAI[NEW,AIL] blob
sn#408287 filedate 1979-01-08 generic text, type C, neo UTF8
COMMENT ⊗ VALID 00015 PAGES
C REC PAGE DESCRIPTION
C00001 00001
C00002 00002 TITLE GRUMP
C00004 00003 LOAD2: XWD INTF,LD
C00009 00004 PROG:
C00012 00005 NAMEB:
C00013 00006 LDB W,IBUF+1
C00016 00007 TBYTES: MOVEI A,11
C00019 00008 DECX: TRZE F,OPTYPF
C00021 00009 BEGIN OPDEFS
C00028 00010 POLFIX:
C00030 00011 F4LD: PUSHJ P,WORD SPECIAL FORMAT FOR F4
C00033 00012 ENDF4: MOVEI T,[ASCIZ /STARTING ADDRESS/]
C00036 00013 DATAS: PUSHJ P,WORD
C00039 00014 TDEC: MOVEI A,11
C00040 00015 GET FILE SPEC FROM TTY LINE
C00043 ENDMK
C⊗;
TITLE GRUMP
;PROGRAM TO PRINT OUT A REL FILE IN A READABLE FORMAT
↓P←17 ;PDL
E←16 ;COUNT, FOR INPUT (BY BLOCK)
A←15 ;TEMP REGISTER
W←14 ;WORDS READ ARE RETURNED HERE
T←13 ;TEMP REGISTER
Q←12 ;RETURN RELOCATION BITS HERE
R←11 ;STORE RELOCATION BITS HERE
T1←10
T2←7
F←0 ;FLAGS
HSW←←1 ;HALF WORD FLAG
↓ LOADVR ←← 54 ;LOADER VERSION NUMBER
OPTYPF←←2 ;OPCODE HAS BEEN TYPED
BITTAB: FOR I←0,20,1 <
1⊗I>
;ROUTINE TO READ A WORD
WORD: SOSG IBUF+2 ;ANY LEFT?
JRST WORD2 ;NO
WORD1: ILDB W,IBUF+1 ;YES, GET IT
POPJ P,
WORD2: INPUT 1,0 ;READ A BLOCK
STATZ 1,740000
JRST [MOVEI T,[ASCIZ /
INPUT ERROR
/]
CALLI T,3
CALLI 12]
STATZ 1,20000
CALLI 12 ;EOF
JRST WORD1
;READ A WORD WITH RELOCATI⊂ON
RWORD: TRNN E,377777 ;TEST FOR END OF BLOCK
JRST LD ;GO DO NEXT BLOCK
RWORD1: AOBJN E,RWORD2 ;TEST FOR DATA WORD
SKIPE IDXFLG# ;ARE WE INDEX-BLOCKING?
JRST RWORD2 ; YES, IGNORE RELOCATION
PUSHJ P,WORD ;READ RELOCATION WORD
MOVE R,W ;GET INTO RELOC REGISTER
HRLI E,-22 ;SET RELOCATION COUNT
RWORD2: PUSHJ P,WORD
SETZ Q, ;ZERO RELOC BITS
ROTC R,2 ;GET 2 NEW BITS
POPJ P,
LOAD2: XWD INTF,LD
XWD POLFIX,PROG
XWD LINK,SYM
XWD ILLFMT,HISEG
XWD INDEX,ENTR
IFG (54-LOADVR),<
XWD PRGBK,HIGH
XWD LIBBK,NAMEB
LOAD3: XWD ILLFMT,STRT
>; VERSION NOT 54
IFGE (LOADVR-54),<
XWD ALGTP,HIGH
XWD PRGBK,NAMEB
LOAD3: XWD LIBBK,STRT
>;VERSION 54 OR HIGHER
DISPL←LOAD3-LOAD2
STPT: RESET
MOVSI 1,'DSK'
MOVEM 1,DEVNAM
outstr[asciz/File name:/]
MOVE P,[XWD -40,PDL-1]
push p,[sixbit/rel/]
pushj p,getfil
jrst STPT
MOVE 1,DEVNAM
MOVEM 1,DEV1
INIT 1,14 ;GET THE DISK, BUFFERED 36 BIT MODE
DEV1: SIXBIT /DSK/
IBUF
EXIT ;GIVE UP IF NOT THERE
lookup 1,filnam
jrst [ outstr[asciz/File not found.
/]↔ jrst STPT ]
move [sixbit /dsk/]
movem DEVNAM
push p,[sixbit /gru/]
outstr [asciz /Output File (<crlf> for TTY:, default ext is .GRU) :/]
pushj p,getfil
jrst [move [sixbit /tty/]↔movem DEVNAM↔jrst .+1]
MOVE DEVNAM
MOVEM INIT2
ASK: OUTSTR [ASCIZ/Block types (<crlf> for all, ? for help) :/]
INCHWL 1
CAIN 1,15 ;CR
JRST [INCHWL 1 ;SNARF THE LF
MOVSI F,-1 ;WANT 'EM ALL
JRST INIT2A]
CAIN 1,"?"
JRST [OUTSTR [ASCIZ/Add the numbers for the blocks desired.
2 Program 40 End 1000 Polish 20000 Algol
4 Symbols 100 Name 2000 Link 40000 Prg req
10 Hiseg 200 Start 4000 Lvar 100000 Lib req
20 Entry 400 Int req 10000 Index 200000 Fortran
/]
CLRBFI
JRST ASK]
MOVEI 2,0
BUILD: LSH 2,3
SUBI 1,"0"
ADDI 2,(1)
INCHWL 1
CAIE 1,15
JRST BUILD
INCHWL 1
MOVSI F,(2)
INIT2A:
INIT 2,0 ;GET THE OUTPUT GOING
init2: SIXBIT /DSK/
XWD OBUF,0 ;FOR OUTPUT
calli 12 ;Don't WAIT FOR IT
ENTER 2,FILNAM
jrst [outstr [asciz /Can't enter file name/]↔calli 1,12]
LD: MOVE P,[XWD -40,PDL-1]
SETZM IDXFLG
PUSHJ P,WORD ;SHOULD BE A BLOCK HEADER
MOVNI E,400000(W) ;SET COUNT
HLRZ A,W ;THE BLOCK TYPE
CAIN A,14 ;INDEX BLOCK?
SETOM IDXFLG ; YES, DENOTE IT
CAILE A,DISPL*2+1 ;CHECK LEGALITY
JRST ILLFMA ;ILL FORMAT
TSNN F,BITTAB(A) ;DO WE WANT IT?
JRST [IGNORE: PUSHJ P,RWORD
JRST IGNORE]
MOVE T,BLKNAM(A) ;TITLE OF THIS BLOCK
PUSHJ P,OUTASC
HLRZ A,W ;BLOCK TYPE
HRRZ T,LOAD2(A) ;GET THE DISPATCH ADDRESS
CAILE A,DISPL ;RIGHT ONE?
HLRZ T,LOAD2-DISPL-1(A) ;CORRECT ONE
JRST @T ;AND AWAY WE GO
BLKNAM←.-1
[ASCIZ /PROGRAM
LOCATION /]
[ASCIZ /SYMBOLS
/]
[ASCIZ /HISEG-TWOSEG BLOCK
/]
[ASCIZ /ENTRY BLOCK
/]
[ASCIZ /END BLOCK
/]
[ASCIZ /NAME BLOCK
/]
[ASCIZ /STARTING ADDRESS
/]
[ASCIZ /INTERNAL REQUEST
/]
[ASCIZ /POLISH FIXUPS
/]
[ASCIZ /LINK BLOCK
/]
[ASCIZ //]
[ASCIZ /INDEX BLOCK
/]
[ASCIZ /ALGOL BLOCK
**** GRUMP CANNOT HANDLE THIS ****
/]
[ASCIZ /PROGRAM REQUEST
/]
[ASCIZ /LIBRARY REQUEST
/]
PROG:
PROG2: PUSHJ P,RWORD ;GET A WORD WITH RELOC BITS
PUSHJ P,HALVS ;PRINT IT
PROG1: PUSHJ P,RWORD ;NOW THE PROGRAM MATERIAL
PUSHJ P,THALFS ;PRINT WITH A TAB
PUSHJ P,TBYTES
PUSHJ P,TCODE
PUSHJ P,TCRLF
JRST PROG1 ;RWORD WILL GET US OUT OF THIS
STRT:
INTF:
HIGH:
LINK:
HISEG:
PROGC: PUSHJ P,RWORD
PUSHJ P,THALVS
JRST PROGC
ENTR:
ENTR1: PUSHJ P,RWORD
PUSHJ P,TRAD50
JRST ENTR1
INDEX:
INDB2: PUSHJ P,RWORD ;GET XWD 4,COUNT
JUMPL W,INDB5 ;NEXT BLOCK PTR
HRRZS W
PUSH P,W ;SAVE COUNT
INDB3: SOSGE (P) ;COUNT DOWN
JRST INDB4
PUSHJ P,RWORD ;GET A RADIX 50
PUSHJ P,TRAD50
JRST INDB3 ;UNTIL ALL OUT
INDB4: POP P,W
MOVEI T,[ASCIZ ' AT WORD/BLOCK ']
PUSHJ P,OUTASC
PUSHJ P,RWORD
PUSHJ P,THALVS
JRST INDB2
INDB5: PUSH P,W ;SAVE NEXT BLOCK
MOVEI T,[ASCIZ / NEXT BLOCK AT /]
PUSHJ P,OUTASC
POP P,T
HRRZS T
PUSHJ P,OCP1
PUSHJ P,TCRLF
JRST INDB2
ALGTP:
JRST ILLFMT
PRGBK:
LIBBK:
PRGB2: PUSHJ P,RWORD ;GET A WORD
PUSH P,W ;SAVE NAME
PUSHJ P,RWORD ;GET PPN
PUSH P,W ;SAVE IT TOO
PUSHJ P,RWORD ;GET DEVICE
MOVEI A,11
PUSHJ P,OCHR
JUMPE W,NODEV
PUSHJ P,OUTSIX
MOVEI A,":"
PUSHJ P,OCHR
NODEV:
MOVE W,-1(P)
PUSHJ P,OUTSIX ;ASSUME IT'S A FILE NAME
MOVEI T,[ASCIZ /.REL/]
PUSHJ P,OUTASC
MOVE W,(P) ;GET PPN
JUMPE W,NOPP1
HLRZS W ;P FIRST
MOVEI A,"["
PUSHJ P,OCHR
PUSHJ P,OUTSIX
MOVEI A,","
PUSHJ P,OCHR
NOPP1: POP P,W
JUMPE W,NOPPN
HRRZS W ;NOW PN
PUSHJ P,OUTSIX
MOVEI A,"]"
PUSHJ P,OCHR
NOPPN: PUSHJ P,TCRLF
JRST PRGB2
OUTSIX: SETZM SIXBK
SETZM SIXBK+1
MOVE T1,[POINT 6,W]
MOVE T2,[POINT 7,SIXBK]
MOVEI Q,6
SIX1: ILDB A,T1
SKIPN A
SOJA Q,SIX1
SIX2: ADDI A,40 ;CONVERT TO ASCII
IDPB A,T2
ILDB A,T1
SOJN Q,SIX2
MOVEI T,SIXBK
JRST OUTASC
NAMEB:
PUSHJ P,RWORD
PUSHJ P,RAD50
JRST PROGC
SYM:
SYM1: PUSHJ P,RWORD
MOVEM W,SVSYM#
PUSHJ P,TRAD51
PUSHJ P,SYMVAL
JRST SYM1
SYMVAL: LDB W,[POINT 4,SVSYM,3]
CAIE W,14
JRST [PUSHJ P,RWORD
JRST THALVS]
PUSHJ P,RWORD
TLZN W,400000 ;CHECK ADDITIVE
JRST PRLOC
MOVEI T,[ASCIZ / ADD /]
PUSHJ P,OUTASC
TLZN W,200000 ;CHECK LEFT HALF
JRST NOLFT
MOVEI T,[ASCIZ /LEFT /]
PUSHJ P,OUTASC
NOLFT: TLZN W,100000 ;CHECK SYMBOL TABLE FIXUP
JRST PRLOC
JRST RAD50
PRLOC: JRST THALVS
LDB W,IBUF+1
JRST IFLP1
IFLP: PUSHJ P,WORD
IFLP1: PUSH P,W
PUSHJ P,RAD51
POP P,W
PUSHJ P,THALVS
JRST IFLP
OUTASC: HRLI T,(<POINT 7,0>)
JRST .+2
PUSHJ P,OCHR
ILDB A,T
JUMPN A,.-2
POPJ P,
OCP: SKIPA T1,[2]
OCP1: MOVEI T1,6
OCP2: LSH T,3
LDB A,[POINT 3,T,17]
ADDI A,"0"
PUSHJ P,OCHR
SOJG T1,OCP2
CPOPJ: POPJ P,
THALFS: MOVEI A,11
PUSHJ P,OCHR
HALFS: HLRZ T,W
PUSHJ P,OCP1
MOVEI A,"'"
TRNE Q,2
PUSHJ P,OCHR
MOVEI A," "
PUSHJ P,OCHR
HRRZ T,W
PUSHJ P,OCP1
MOVEI A,"'"
TRNE Q,1
PUSHJ P,OCHR
MOVEI A," "
PUSHJ P,OCHR
POPJ P,
THALVS: MOVEI A,11
PUSHJ P,OCHR
HALVS: PUSHJ P,HALFS
TCRLF: MOVEI A,15
PUSHJ P,OCHR
MOVEI A,12
OCHR: SOSG OBUF+2
OUTPUT 2,0
IDPB A,OBUF+1
POPJ P,
TRAD51: MOVEI A,11
PUSHJ P,OCHR
RAD51: LDB T,[POINT 4,W,3]
LSH T,16
PUSHJ P,OCP
MOVEI A,40
PUSHJ P,OCHR
MOVE T,W
TLZ T,740000
MOVNI T1,6
PUSHJ P,SP1
JUMPE Q,CPOPJ
MOVEI T,[ASCIZ / (/]
PUSHJ P,OUTASC
MOVEI A,"L"
TRNE Q,2
PUSHJ P,OCHR
MOVEI A,"R"
TRNE Q,1
PUSHJ P,OCHR
MOVEI A,")"
JRST OCHR
SP1: IDIVI T,50
HRLM W,(P)
AOSGE T1
PUSHJ P,SP1
HLRZ T,(P)
JUMPE T,ADD40
ADDI T,60-1
CAILE T,71
ADDI T,101-72
CAILE T,132
SUBI T,134-44
CAIN T,43
MOVEI T,56
SKIPA A,T
ADD40: MOVEI A,40(T)
JRST OCHR
TRAD50: MOVEI A,11
PUSHJ P,OCHR
RAD50: PUSHJ P,RAD51
JRST TCRLF
ILLFMA:
TSNN F,BITTAB+20
JRST IGNORE
CAIN A,400
JRST F4LD
ILLFMT: MOVEI T,[ASCIZ /
ILLEGAL FORMAT
/]
PUSHJ P,OUTASC
LDB W,IBUF+1
JRST ILF2
ILF: PUSHJ P,WORD
ILF2: PUSH P,W
PUSHJ P,RAD51
POP P,W
PUSHJ P,THALVS
JRST ILF
TBYTES: MOVEI A,11
PUSHJ P,OCHR
BYTES: PUSH P,W
MOVEI T2,6
JRST .+3
BYTLP: MOVEI A,","
PUSHJ P,OCHR
MOVEI T,0
LSHC T,7
SKIPL CHRTAB(T)
JRST [MOVEI A,40
PUSHJ P,OCHR
MOVEI A,(T)
PUSHJ P,OCHR
MOVEI A,40
PUSHJ P,OCHR
JRST BYTCNT]
MOVEI T1,3
LSH T,11
PUSHJ P,OCP2
BYTCNT: SOJG T2,BYTLP
POP P,W
POPJ P,
TCODE: MOVEI A,11
PUSHJ P,OCHR
CODE: PUSH P,W
LDB W,[POINT 9,W,8] ;GET OPCODE PART
ANDCMI F,OPTYPF ;NOT TYPED YET
MOVEI T1,0 ;NUMBER OF BYTES TO SKIP
MOVE T,BTAB ;GET POINTER TO START OF TABLE
DC1: ILDB T2,T
CAILE T2,40
CAIL T2,73
SOJGE T1,DC1 ;SKIP REQUIRED NUMBER
JUMPG T1,DC1 ;BUT DO NOT COUNT LETTERS
SUBI T2,40
JUMPE T2,DECX ;A STOP CODE
JUMPG T2,DC2 ;A TRANSFER OR A LETTER
DPB T2,[POINT 5,PNTRX,7] ;DEPOSIT POSITION FIELD OF TEST
ANDCMI T2,-4
ADDI T2,1 ;GE SIZE
DPB T2,[POINT 6,PNTRX,11] ;AND DEPOSIT
LDB T1,PNTRX ;GET NUMBER TO SKIP
JRST DC1 ;AND DO IT
DC2: HRREI T2,-33(T2)
JUMPL T2,DECT ;GO PRINT
IDIVI T2,3 ;A TRANSFER, GET WORD AND BYTE NUMBER
MOVE T1,BTAB(T1) ;GET CORRECT BYTE POINTER
ADDI T1,(T2) ;AND ADD IN WORD NUMBER
MOVE T,T1
MOVEI T1,0 ;SET SKIP TO 0
JRST DC1
DECT: TRO F,OPTYPF
MOVEI A,133(T2)
PUSHJ P,OCHR
JRST DC1
CHRTAB:
FOR I←0,37,1 <
-1> ;ANYTHING LESS THAN SPACE
FOR I←40,172,1 <
0> ;SPACE THROUGH LOWERCASE Z
FOR I←173,177,1 <
-1> ;THE REST
DECX: TRZE F,OPTYPF
JRST DIDCOD ;AN OPCODE WAS TYPED
LDB T,[POINT 9,(P),8]
LSH T,11
MOVEI T1,3
PUSHJ P,OCP2 ;PRINT AS A NUMBER
DIDCOD: MOVEI A," "
PUSHJ P,OCHR
LDB T,[POINT 4,(P),12] ;GET AC FIELD
JUMPE T,NOAC
LSH T,14
PUSHJ P,OCP ;GO PRINT IT
MOVEI A,","
PUSHJ P,OCHR ;AND A COMMA
NOAC: LDB T,[POINT 1,(P),13] ;THE INDIRECT BIT
JUMPE T,NOINDR
MOVEI A,"@"
PUSHJ P,OCHR
NOINDR: HRRZ T,(P) ;GET ADDRESS FIELD
PUSHJ P,OCP1 ;PRINT IT
MOVEI A,"'"
TRNE Q,1
PUSHJ P,OCHR ;IF RELOC, INDICATE IT
LDB T,[POINT 4,(P),17]
JUMPE T,NOIND ;NO INDEX FIELD
MOVEI A,"("
PUSHJ P,OCHR
LSH T,14
PUSHJ P,OCP
MOVEI A,")"
PUSHJ P,OCHR
NOIND: POP P,W ;GET REGISTER BACK
MOVEI T,[ASCIZ / (R)/]
TRNE Q,2 ;WAS LEFT HALF RELOC?
JRST OUTASC ;GO PRINT
POPJ P, ;NO, RETURN
PNTRX: W
BTAB: POINT 10,TBL
POINT 10,TBL,9
POINT 10,TBL,19
BEGIN OPDEFS
DEFINE P (A)
<OUTP A&70/2+A&7-1
>
DEFINE G (A)
<OUTP A+73
>
DEFINE T (A)
<FOR Bε<A> <OUTP "B"-40
>>
DEFINE S (Q)
<OUTP 40
>
DEFINE L (A)
<IFGE CLOC+73-2000,<PRINTX OPTABLE TOO LONG>
A←←CLOC
>
;TO GET THE EFFECT OF TWO PASSES, "TABLE" IS EXPANDED ONCE TO GET THE LABEL
;DEFINITIONS WITHOUT DATA GENERATION, THEN "OUTP" IS REDEFINED AND "TABLE"
;EXPANDED ONCE MORE.
DEFINE OUTP (A)
<CLOC←←CLOC+1
>
DEFINE BYT9 (A)
<FOR B⊂(A) <B
>>
DEFINE TABLE <
BYT9 <P 63,G %UUO,G %FLO,G %HAK,G %ACCP,G %BOOLE,T H,G %HWT,T T,G %ACBM>
BYT9 <P 21,G %BD,T CON,P 11,G %OI,T S,P 01,G %Z,G %O>
BYT9 <L %BD,P 01,T BLK,G %IO,T DATA,L %IO,P 11,G %I,G %O,L %OI,P 1,G %O,G %I>
BYT9 <L %UUO,P 51,S,P 32,G %U40,G %U50,G %U60,P 21,G %U703,P 11,G %USET>
BYT9 <P 1,T LOOKU,G %P,T ENTE,G %R,L %USET,T USET,P 1,G %I,G %O>
BYT9 <L %U40,P 3,G %U47,T INI,G %T,S,T SPCWA,G %R,S,S,S,L %U47,T CALL>
BYT9 <P 1,S,G %I,L %U60,P 21,G %U603,P 1,T IN,G %BPUT,T OUT,L %BPUT>
BYT9 <P 11,T BU,L %F,T F,S,T PU,G %T,L %U50,P 3,T OPE,G %N,T TTYUU,G %O,S,S,S>
BYT9 <T RENAM,G %E,T I,G %N,T OU,G %T,L %U603,P 1,G %U6062,T STAT>
BYT9 <P 11,L %O,T O,S,L %Z,T Z,S,L %U6062,P 11,T S,G %U62,T G,L %U62>
BYT9 <T ETST,G %S,L %U703,P 2,T CLOS,G %E,T RELEA,G %S,T MTAP,G %E>
BYT9 <T UGET,G %F>
BYT9 <L %FLO,P 51,G %BYTE,T F,P 32,T AD,G %A,T SB,G %A,T MP,G %A,T DV>
BYT9 <L %A,P 21,G %LMB,T R,G %IMB,L %LMB,P 2,S,L %L,T L,S,L %M,T M,S,L %B>
BYT9 <L %B,T B,S,L %BYTE,P 32,G %100,G %110,G %120>
BYT9 <P 3,T UF,G %PA,T DF,G %N,T FS,G %C,T IB,L %P,T P,S>
BYT9 <T I,G %LD,L %LD,T LD,G %B,T I,G %DP,L %DP,T DP,G %B>
BYT9 <L %110,T D,P 3,T FA,L %D,T D,S,T FS,G %B,T FM,G %P,T FDV,S>
BYT9 <T AD,G %D,T SU,G %B,T MUL,S,T DIV,S>
BYT9 <L %100,P 21,S,P 2,T JSY,G %S,T ADJS,G %P,S,S>
BYT9 <L %120,P 3,T DMOV,G %E,T DMOV,G %N,T FIX,S,T EXTEND,S>
BYT9 <T DMOVE,G %M,T DMOVN,G %M,T FIXR,S,T FLTR,S>
BYT9 <L %HAK,P 33,G %MV,L %MV,T MOV,G %MO,G %ML,G %DV,G %SH,G %H1>
BYT9 <G %JP,P 21,T ADD,G %IMB,T SU,L %BIMB,T B,L %IMB,P 2>
BYT9 <S,L %I,T I,S,G %M,G %B,L %MO,P 22,L %EIMS,T E,G %IMS,T S>
BYT9 <G %IMS,T N,G %IMS,T M,L %IMS,P 2,S,G %I,G %M,L %S,T S,S>
BYT9 <L %ML,P 21,T I,G %ML1,L %ML1,T MUL,G %IMB,L %DV,P 21,T I,G %DV1>
BYT9 <L %DV1,T DI,L %DV2,T V,G %IMB,L %H1,P 3,T EXC,G %S3,T BL,L %T>
BYT9 <T T,S,G %AO,L %AO,T AOBJ,G %AOB,T JRS,G %T,T JFC,G %L,T XC,G %T>
BYT9 <T MA,G %P,L %AOB,P 1,G %P,G %N,L %JP,P 3,G %PU,L %PU,T PUSH>
BYT9 <G %PUS,G %PO,L %PO,T POP,G %POP,T JS,L %R,T R,S,T JS,G %P>
BYT9 <T JS,L %PA,T A,S,T JR,G %PA,L %PUS,P 1,L %J,T J,S,S,L %POP>
BYT9 <P 1,S,G %J,L %SH,P 2,T A,G %S2,T ROT,G %S1,T L,L %S2,T S,L %S3>
BYT9 <T H,G %S1,P 21,T JFF,G %O,T KAFIX,S,L %S1,P 21,S,L %C,T C,S>
BYT9 <L %ACCP,P 42,T CA,G %CA1,G %SJ,T A,G %JS,T S,L %JS,T O,P 31>
BYT9 <T J,G %COMP,T S,G %COMP,L %CA1,P 31,T I,G %COMP,T M,G %COMP>
BYT9 <L %SJ,P 31,T JUM,G %PSJ,T SKI,L %PSJ,T P,L %COMP>
BYT9 <P 3,S,G %L,L %E,T E,S,T L,G %E,G %PA,T G,G %E,L %N,T N,S,T G,S>
BYT9 <L %HWT,P 51,G %HW1,P 21,T R,G %HW2,T L,L %HW2,T R,G %HW3,L %HW1>
BYT9 <P 21,T L,G %HW4,T R,L %HW4,T L,L %HW3,P 32,G %IMS,T Z,G %IMS,T O>
BYT9 <G %IMS,G %EIMS>
BYT9 <L %ACBM,P 31,G %AC1,P 1,T D,G %AC2,T S,G %AC2,L %AC1,P 1,T R>
BYT9 <G %AC2,T L,L %AC2,P 42,T N,G %EAN,T Z,G %EAN,T C,G %EAN,T O>
BYT9 <L %EAN,P 12,S,G %E,G %PA,G %N>
BYT9 <L %CB,T C,G %BIMB,L %BOOLE,P 24,G %ST,L %AN,T AND,G %B2,G %AN>
BYT9 <G %ST,G %AN,G %ST,T X,L %OR,T OR,G %B2,T I,G %OR,G %AN,T EQ>
BYT9 <G %DV2,G %ST,G %OR,G %ST,G %OR,G %OR,L %ST,T SET,L %B2>
BYT9 <P 24,T Z,G %IMB,G %IMB,L %CA,T C,G %TA,L %TM,T M,G %IMB,L %CM>
BYT9 <T C,G %TM,L %TA,T A,G %IMB,G %IMB,G %IMB,T C,G %BIMB,G %IMB,G %CA>
BYT9 <G %CA,G %CM,G %CM,G %CB,T O,G %IMB>>
;END OF THE DEFINITION OF "TABLE"
;EXPAND "TABLE" ONCE TO GET THE LABELS DEFINED.
CLOC←←0 ;INITIALIZE LOCATION COUNTER.
XLIST
TABLE
LIST
;NOW REDEFINE "OUTP" TO CAUSE NEXT EXPANSION OF "TABLE" TO GENERATE DATA
DEFINE OUTP (A)
<BINRY←←BINRY⊗=10+A
BINC←←BINC-1
IFE BINC,<
BINRY⊗6
BINRY←←0
BINC←←3
>
CLOC←←CLOC+1
>
BINRY←←0
BINC←←3
CLOC←←0
↑TBL: ;CAUSE ACTUAL EXPANSION OF THE TABLE TO OCCUR HERE.
XLIST
TABLE
REPEAT BINC,<BINRY←←BINRY⊗=10>
IFN BINRY,<BINRY⊗6>
LIST
BEND OPDEFS
POLFIX:
TLO F,HSW
RPOL: PUSHJ P,RDHLF
MOVEI T,ASCTAB(W)
PUSHJ P,OUTASC
MOVEI T,[ASCIZ / (R)/]
TRNE Q,1
PUSHJ P,OUTASC
CAILE W,14
JRST STROP
CAILE W,2
JRST RPOL1
MOVE A,W
PUSHJ P,RDHLF
JUMPE A,HLFOP
MOVE T1,W
HRL T1,Q
PUSHJ P,RDHLF
HRLM T1,W
LSH T1,-=17
ANDI T1,2
IOR Q,T1
SOJE A,HLFOP
PUSHJ P,TRAD50
JRST RPOL
HLFOP: PUSHJ P,THALVS
JRST RPOL
RPOL1: PUSHJ P,TCRLF
JRST RPOL
ASCIZ / SMA/
ASCIZ / SML/
ASCIZ / SMR/
ASCIZ / SAL/
ASCIZ / SLH/
ASCIZ / SRH/
ASCTAB: ASCIZ / OPH/
ASCIZ / OPF/
ASCIZ / OPG/
ASCIZ / +/
ASCIZ / -/
ASCIZ / */
ASCIZ . /.
ASCIZ / AND/
ASCIZ / OR/
ASCIZ / LSH/
ASCIZ / XOR/
ASCIZ / NOT/
ASCIZ / NEG/
STROP: CAIGE W,-3
JRST SYMSTR
PUSHJ P,RDHLF
PUSHJ P,THALVS
STOR1: PUSHJ P,RWORD
JRST ILLFMT
RDHLF: TLON F,HSW
JRST NORD
PUSHJ P,RWORD
TLZ F,HSW
MOVEM W,SVHWD
MOVEM Q,SVHWQ#
HLRZS W
LSH Q,-1
POPJ P,
NORD: HRRZ W,SVHWD#
MOVE Q,SVHWQ
ANDI Q,1
POPJ P,
SYMSTR: PUSHJ P,RDHLF
HRL T1,W
HRR T1,Q
PUSHJ P,RDHLF
HLL W,T1
LSH T1,1
ANDI T1,2
IOR Q,T1
PUSHJ P,TRAD51
PUSHJ P,RDHLF
HRL T1,W
HRR T1,Q
PUSHJ P,RDHLF
HLL W,T1
LSH T1,1
ANDI T1,2
IOR Q,T1
PUSHJ P,TRAD50
JRST STOR1
F4LD: PUSHJ P,WORD ;SPECIAL FORMAT FOR F4
HLRZ T,W ;GET LEFT HALF
CAIE T,-1 ;IS IT HEADER TYPE
JRST NOHEAD ;NO, GO PROCESS A 'STANDARD' WORD
CAMN W,[-2]
JRST ENDF4
LDB T,[POINT 6,W,23] ;GET HEADER TYPE
ANDI W,7777
JUMPE T,PROGL
CAIN T,50
JRST ABS
CAIN T,31
JRST MDLBL
CAIN T,60
JRST GLOB
CAIN T,70
JRST DATAS
JRST ILLFMT
ABS: MOVE T1,W
ABS1: PUSHJ P,WORD
PUSHJ P,THALVS
SOJG T1,ABS1
JRST F4LD
PROGL: MOVEI T,[ASCIZ /PROGL
/]
PROGL1: PUSHJ P,OUTASC
PUSHJ P,TDEC
MOVEI A," "
PUSHJ P,OCHR
PROGL2: PUSHJ P,WORD
PUSHJ P,RAD50
JRST F4LD
MDLBL: MOVEI T,[ASCIZ /MDLBL
/]
JRST PROGL1
GLOB: MOVEI T,[ASCIZ /GLOBAL
/]
PUSHJ P,OUTASC
JRST PROGL2
NOHEAD: HLRZ T,W
MOVEI A,11
PUSHJ P,OCHR
PUSHJ P,OCP1
MOVEI A," "
PUSHJ P,OCHR
PUSHJ P,NOHD1
JRST F4LD
NOHD1: LDB A,[POINT 5,W,23]
MOVEI T,0
CAIN A,0
MOVEI T,[ASCIZ /PLT /]
CAIN A,1
MOVEI T,[ASCIZ /ARRY REF /]
CAIN A,6
MOVEI T,[ASCIZ /GLSUB /]
CAIN A,11
MOVEI T,[ASCIZ /CONS /]
CAIN A,20
MOVEI T,[ASCIZ /SCALAR /]
CAIN A,22
MOVEI T,[ASCIZ /ARRAY /]
CAIN A,26
MOVEI T,[ASCIZ /PTMP /]
CAIN A,27
MOVEI T,[ASCIZ /TTMP /]
CAIN A,31
MOVEI T,[ASCIZ /MLT /]
JUMPE T,ILLFMT
PUSHJ P,OUTASC
PUSH P,W
ANDI W,7777
PUSHJ P,DEC
POP P,W
MOVEI T,[ASCIZ /(D)/]
TRNE W,400000
PUSHJ P,OUTASC
JRST TCRLF
ENDF4: MOVEI T,[ASCIZ /STARTING ADDRESS/]
PUSHJ P,OUTASC
PUSHJ P,WORD
PUSHJ P,THALVS
MOVEI T,[ASCIZ /TEMPS/]
PUSHJ P,OUTASC
PUSHJ P,WORD
PUSHJ P,TDEC
MOVEI T,[ASCIZ /
CONSTANTS/]
PUSHJ P,OUTASC
PUSHJ P,WORD
PUSH P,W
PUSHJ P,TDEC
PUSHJ P,TCRLF
POP P,T1
JUMPE T1,NOCON
CONP: PUSHJ P,WORD
PUSHJ P,THALVS
SOJG T1,CONP
NOCON: MOVEI T,[ASCIZ /GLOBAL SUBPROGRAMS/]
PUSHJ P,OUTASC
PUSHJ P,WORD
PUSH P,W
PUSHJ P,TDEC
PUSHJ P,TCRLF
POP P,T2
JUMPE T2,NOSUBS
SUBS1: PUSHJ P,WORD
PUSHJ P,TRAD50
SOJG T2,SUBS1
NOSUBS: MOVEI T,[ASCIZ /SCALARS
/]
PUSHJ P,OUTASC
PUSHJ P,WORD
JUMPE W,NOSCAL
MOVE T2,W
SCAL1: PUSHJ P,WORD
PUSH P,W
PUSHJ P,WORD
PUSHJ P,TRAD51
POP P,W
PUSHJ P,THALVS
SUBI T2,1
SOJG T2,SCAL1
NOSCAL: MOVEI T,[ASCIZ /ARRAYS
/]
PUSHJ P,OUTASC
PUSHJ P,WORD
JUMPE W,NOARY
MOVE T2,W
ARAY1: PUSHJ P,WORD
PUSH P,W
PUSHJ P,WORD
PUSHJ P,TRAD51
POP P,W
PUSHJ P,THALVS
SUBI T2,1
SOJG T2,ARAY1
NOARY: MOVEI T,[ASCIZ /ARRAY REFS
/]
PUSHJ P,OUTASC
PUSHJ P,WORD
JUMPE W,NOREF
MOVE T1,W
REF1: PUSHJ P,WORD
PUSHJ P,THALVS
PUSHJ P,WORD
PUSHJ P,THALVS
SUBI T1,1
SOJG T1,REF1
NOREF: MOVEI T,[ASCIZ /VARIABLE AREA /]
PUSHJ P,OUTASC
PUSHJ P,WORD
PUSHJ P,DEC
PUSHJ P,TCRLF
MOVEI T,[ASCIZ /COMMON BLOCKS
/]
PUSHJ P,OUTASC
PUSHJ P,WORD
JUMPE W,LD
MOVE T2,W
CMB1: PUSHJ P,WORD
PUSHJ P,TRAD51
PUSHJ P,WORD
PUSHJ P,THALVS
SUBI T2,2
SOJG T2,CMB1
JRST LD
DATAS: PUSHJ P,WORD
MOVEM W,N3#
PUSHJ P,WORD
MOVEM W,N2
PUSHJ P,WORD
MOVEM W,N1#
MOVE T2,N3
MOVEI T,[ASCIZ /DATA SEQUENCES
/]
PUSHJ P,OUTASC
JUMPN T2,NOSEQ
SEQ2: PUSHJ P,WORD
CAMN W,[MOVE 13,12]
JRST CAD
CAMN W,[PUSHJ 17,1]
JRST DOINIT
CAMN W,[PUSHJ 17,2]
JRST DOADV
CAMN W,[PUSHJ 17,0]
JRST STOR
HLRZ A,W
CAIN A,(<IMULI 12,>)
JRST MULTIP
MOVEI T,0
CAIN A,(<IMUL 12,>)
MOVEI T,[ASCIZ / MUL /]
CAIN A,(<ADD 12,>)
MOVEI T,[ASCIZ / ADD /]
JUMPE T,ILLFMT
PUSHJ P,OUTASC
PNTR: LDB A,[POINT 6,W,23]
MOVEI T,[ASCIZ /CONST /]
CAIN A,0
MOVEI T,[ASCIZ /DOVT /]
PUSHJ P,OUTASC
ANDI W,7777
DO1: PUSHJ P,DEC
PUSHJ P,TCRLF
COMSQ: SOJG T2,SEQ2
NOSEQ: MOVE T2,N2#
MOVEI T,[ASCIZ /DATA ITEMS
/]
PUSHJ P,OUTASC
JUMPN T2,NOITEM
ITEM1: PUSHJ P,WORD
SUBI T2,(W)
PUSH P,W
PUSHJ P,THALVS
EXCH T2,(P)
HRRZS T2
JUMPE T2,NOCNT
CNT2: PUSHJ P,WORD
MOVEI A,11
PUSHJ P,OCHR
PUSHJ P,THALVS
SOJG T2,CNT2
NOCNT: POP P,T2
SOJG T2,ITEM1
MOVEI T,[ASCIZ /DATA CONSTANTS
/]
PUSHJ P,OUTASC
NOITEM: MOVE T2,N1
JUMPN T2,F4LD
SEQ1: PUSHJ P,WORD
PUSHJ P,THALVS
SOJG T2,SEQ1
JRST F4LD
CAD: PUSHJ P,WORD
MOVEI T,[ASCIZ / CAD /]
PUSHJ P,OUTASC
JRST PNTR
DOINIT: MOVEI T,[ASCIZ / DOINIT /]
PUSHJ P,OUTASC
PUSHJ P,WORD
JRST DO1
DOADV: MOVEI T,[ASCIZ / DOADV /]
PUSHJ P,OUTASC
PUSHJ P,WORD
PUSH P,W
HLRZS W
PUSHJ P,DEC
MOVEI A,","
PUSHJ P,OCHR
POP P,W
HRRZS W
JRST DO1
MULTIP: MOVEI T,[ASCIZ / IMULI /]
PUSHJ P,OUTASC
HRRZS W
JRST DO1
STOR: MOVEI T,[ASCIZ / STORE /]
PUSHJ P,OUTASC
PUSHJ P,WORD
PUSH P,W
HLRZS W
PUSHJ P,DEC
MOVEI A,","
PUSHJ P,OCHR
POP P,W
PUSHJ P,NOHD1
JRST COMSQ
TDEC: MOVEI A,11
PUSHJ P,OCHR
DEC: MOVE T,W
PUSH P,W
PUSHJ P,DEC1
POP P,W
POPJ P,
DEC1: IDIVI T,12
HRLM W,(P)
SKIPE T
PUSHJ P,DEC1
HLRZ A,(P)
ADDI A,"0"
JRST OCHR
;GET FILE SPEC FROM TTY LINE
begin getfil
opdef go [jrst]
define pop0j <popj p,>
define pop2j <jrst[sub p,[2,,2]↔jrst @2(p)]>
define pop3j <jrst[sub p,[3,,3]↔jrst @3(p)]>
define arg2 <-1(p)>
↑getfil:
SETZM FILNAM↔SETZM EXTION
SETZM EXTION+1↔SETZM PPPN
MOVE 4,[POINT 6,FILNAM,-1]↔MOVEI 2,6
INCHWL 1↔CAIN 1,15↔GO[INCHWL↔POP2J]↔AOS(P)
JRST L+1
L: INCHWL 1
CAILE 1,"z"↔POP2J
CAIL 1,"a"↔SUBI 1,40 ;CONVERT LOWER CASE
CAIN 1,":"↔GO[MOVE 4,FILNAM↔MOVEM 4,DEVNAM↔SOS (P)↔GO GETFIL]
CAIN 1,"."↔GO[MOVE 4,[POINT 6,EXTION,-1]↔MOVEI 2,3↔GO L]
CAIN 1,"["↔GO[MOVE 4,[POINT 6,PPPN,-1] ↔MOVEI 2,3↔GO L]
CAIN 1,","↔GO[HLRZ PPPN
PUSHJ P,[PPJUST: JUMPE [OUTSTR[ASCIZ/BAD P,PN
/]↔ CLRBFI↔SOS -1(P)↔POP3J]
TRNE 77↔POP0J↔LSH -6↔GO PPJUST]
HRLM PPPN↔MOVE 4,[POINT 6,PPPN,17]↔MOVEI 2,3↔GO L]
CAIN 1,"]"↔GO[HRRZ PPPN↔PUSHJ P,PPJUST
HRRM PPPN↔INCHWL 1↔GO FINQ]
FINQ: CAIN 1,15↔GO EOL ;END OF THE LINE.
CAIN 1,12↔POP2J
CAIG 1," "↔GO L ;IGNORE GARBAGE.
SOJL 2,L↔SUBI 1,40↔IDPB 1,4↔GO L
EOL: INCHWL 2
SKIPN 2,EXTION↔MOVE 2,ARG2↔MOVEM 2,EXTION
POP2J
BEND
DEVNAM: 0
FILNAM: 0 ;FILE NAME.
EXTION: 0 ;EXTENSION.
0
PPPN: 0 ;PROJECT-PROGRAMMER.
SIXBK: BLOCK 2
OBUF: BLOCK 3
IBUF: BLOCK 3
PDL: BLOCK 40
END STPT